package com.ssm.forum.rpc.service.impl.user;

import com.github.pagehelper.PageInfo;
import com.jee.ssm.common.web.param.ParamMap;
import com.ssm.forum.dao.mapper.user.UserDao;
import com.ssm.forum.dao.model.user.User;
import com.ssm.forum.rpc.api.user.UserService;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.List;
import java.util.Map;

/**
* app用户管理 Service
* @author GaoXiang
* @version 1.0
*/
@Service
public class UserServiceImpl implements UserService {

    @Resource
    private UserDao userDao;


    /**
    * 保存数据
    * @param user 实体对象
    * @return 实体id
    * @throws Exception 数据保存异常
    */
    public Integer insert(User user) throws Exception {
        return userDao.insert(user);
    }

    /**
    * 根据 id 修改
    * @param user 带id的实体对象
    * @return 受影响的行数
    * @throws Exception 数据修改异常
    */
    public Integer updateById(User user) throws Exception {
        return userDao.updateById(user);
    }

    /**
    * 根据 id 删除
    * @param id 数据id
    * @return 受影响的行数
    * @throws Exception 数据删除异常
    */
    public Integer deleteById(String id) throws Exception {
        return userDao.deleteById(id);
    }

    /**
    * 根据 id 查找
    * @param id 实体id
    * @return 实体
    */
    public User selectById(String id) {
        return userDao.selectById(id);
    }

    /**
    * 根据 id 批量删除
    * @param ids 要删除的id
    * @return 影响的行数
    * @throws Exception 数据删除异常
    */
    public Integer deleteByIds(List<String> ids) throws Exception {
        return userDao.deleteByIds(ids);
    }

    /**
    * 查询列表
    * @param map 参数
    * @return 列表
    */
    public PageInfo<User> list(Map map) {
        return userDao.list(map);
    }

    /**
    * 查询列表 带分页
    * @param map 参数
    * @param page 页码
    * @param size 每页大小
    * @return 列表
    */
    public PageInfo<User> list(Map map,int page,int size) {
        return userDao.list(map,page,size);
    }



    /**
     * 根据 phone 查找
     * @param phone phone
     * @return 实体
     */
    public User selectByPhone(String phone) {
        return userDao.selectByPhone(phone);
    }

    public void editHeadPhoto(User user) throws Exception {
        userDao.editHeadPhoto(user);
    }

    /**
     * 查询所有用户
     * @return
     */
    public List<User> chooseUser(){
        return userDao.chooseUser();
    }

    /**
     * 查询列表
     * @param map 参数
     * @param page 页数
     * @param size 每页大小
     * @return 列表
     */
    public PageInfo<User> selectUser(Map map,int page,int size){ return  userDao.selectUser(map,page,size);}


    /**
     * 根据id批量查询
     * @return 列表
     */
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         public PageInfo<User> selectByIds(List<String> ids,int page,int size){ return  userDao.selectByIds(ids,page,size);}



    /**
     * 获取房子下面的住户
     * @param user 参数
     * @return 列表
     */
    public List<User> userList(User user) {
        return userDao.userList(user);
    }

    /**
     * 楼栋下的 居住人信息
     * @param paramMap
     * @return
     */
    public List<User> selectByBuildingId(ParamMap paramMap) {
        return userDao.selectByBuildingId(paramMap);
    }

    /**
     * 单元下的 居住人信息
     * @param paramMap
     * @return
     */
    public List<User> selectByUnitId(ParamMap paramMap) {
        return userDao.selectByUnitId(paramMap);
    }

    /**
     * 小区总人数
     *
     * @param residenceId
     * @return
     */
    public Long countId(String residenceId){
        return userDao.countId(residenceId);
    }

    /**
     * 特殊人群总人数
     *
     * @param residenceId
     * @return
     */
    public Long sensitiveCount(String residenceId){
        return userDao.sensitiveCount(residenceId);
    }

    /**
     * 涉恐人员人数
     *
     * @param residenceId
     * @return
     */
    public Long  terrorismCount(String residenceId){
        return userDao.terrorismCount(residenceId);
    }

    /**
     * 涉稳人员人数
     *
     * @param residenceId
     * @return
     */
    public Long  stabilityCount(String residenceId){
        return userDao.stabilityCount(residenceId);
    }

    /**
     * 重大刑事犯罪前科人员人数
     *
     * @param residenceId
     * @return
     */
    public Long  criminalCount(String residenceId){
        return userDao.criminalCount(residenceId);
    }

    /**
     * 涉毒人数
     *
     * @param residenceId
     * @return
     */
    public Long  drugsCount(String residenceId){
        return userDao.drugsCount(residenceId);
    }

    /**
     * 肇事肇祸精神病人人数
     *
     * @param residenceId
     * @return
     */
    public Long  psychosisCount(String residenceId){
        return userDao.psychosisCount(residenceId);
    }

    /**
     * 重点上访人员人数
     *
     * @param residenceId
     * @return
     */
    public Long  petitionCount(String residenceId){
        return userDao.petitionCount(residenceId);
    }

    /**
     * 60以上
     *
     * @param residenceId
     * @return
     */
    public Long countOld(String residenceId){
        return userDao.countOld(residenceId);
    }
    /**
     * 16以下
     *
     * @param residenceId
     * @return
     */
    public Long countChild(String residenceId){
        return userDao.countChild(residenceId);
    }
    /**
     * 男
     *
     * @param residenceId
     * @return
     */
    public Long countMale(String residenceId){
        return userDao.countMale(residenceId);
    }
    /**
     * 女
     *
     * @param residenceId
     * @return
     */
    public Long countFemale(String residenceId){
        return userDao.countFemale(residenceId);
    }

}
